110- 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO, AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 



112-f 



114 



CHECK PRINTED ON WORKSTATION 
PRINTER, AND MAILED TO PATENT 
AND TRADEMARK OFFICE 



PTO RECEIVES 
CHECK AND CASHES 
AGAINST SANK ACCOUNT 



120 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



126 




INFORMATION REGARDING 
CHECKS PRINTED UPLOADED 
TO CENTRAL OFFICE 
BY REMOTE WORKSTATION 



122- 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



BANK SENDS TO 
CENTRAL OFFICE 

MONTHLY STATEMENT 
OF TRANSACTIONS 

TO CENTRAL OFFICE 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADEO BY WS 



FIG, 1A 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



136 



BILL DUE 
IN 90 DAYS OR 
OTHER PERIOD 



146 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
LAW FIRM 



132 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 



138 



SEND INVOICE 
TO CLIENT (BY 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 



140 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


142 




LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 


144 




LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



FIG. 1B 



210- 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO. AND REQUESTED 
AMOUNT INTO REMOTE WORKSTATION 



212- 



213- 



T 



WORKSTATION ISSUES AUTHORIZATION 
CODE FOR DEBIT OF REQUESTED 
AMOUNT FROM DEPOSIT ACCOUNT 



214 



I 



TRANSMITTAL INCLUDING AUTHORIZATION 
CODE SENT TO EPO/PCT 
(DEPOSIT ACCOUNT AUTHORIZATION) 



EPO/PCT RECEIVES 
TRANSMITTAL AND DEBITS 
DEPOSIT ACCOUNT 



220 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



226 




INFORMATION REGARDING 
AUTHORIZATION UPLOADED 
TO CENTRAL OFFICE BY WS 



218- 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO UW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



CENTRAL OFFICE RECEIVES 
MONTHLY STATEMENT OF- 
ACCOUNT DE8ITS 
IDENTIFIED BY 
AUTHORIZATION CODE 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



FIG. 2A 



I 



0 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



236 



BILL DUE 
IN 90 DAYS OR 
OTHER PERIOD 



246 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
. LAW FIRM 



232 

_J 

EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 







238 
i 




SEND INVOICE 
TO CLIENT (BY 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 


240 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


242 | 



LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 



244 



LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



FIG. 2B 



ENTRY OF RLE NUMBER AND/OR OTHER 
310 J IDENTIFICATION INFO, AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 



TO STEP 
120 OR 220 



TO STEP 
144 OR 214 



313- 



WORKSTATION ELECTRONICALLY 
311 J CONTACTS CENTRAL OFFICE FOR 
CONFIRMATION/APPROVAL 



WORKSTATION ISSUES CHECK 
OR AUTHORIZATION CODE 



CODE OR CHECK SENT 
TO PATENT AGENCY 




TO STEP 
122 OR 222 
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FIG. 3 
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410 



LAW FIRM 



418 
__S 



ACCOUNTING/ 
BILLING 
SYSTEM 



^422 



CHECK 
PRINTING/ 
AUTH. CODE 
SYSTEM 



~ 7~ 

416 



434 
1 



420 
1 



412 



PATENT 
AND 
TRADEMARK 

PAYMENT 
FEE SYSTEM 



432 _ 



424 
i 



426 



PATENT 
AGENCY 



428 
__i 



414 



430 
— 1 



ACCOUNT 



PATENT AGENCY 
OR FINANCIAL 
INSTITUTION 



FIG. 4 
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July 22. 1997 Payee: U.S. Patent k Trcdemork Office 

Fee Code: 101/201 Basic Filing Fee-Utility 
Client Number: 00997 
Matter Number: mx 

Note: This requires special attention. 




July 22, 1997 

Two Thousand AND 0/1OO DOLLARS 
U.S. Patent k Trademark Office 


$ 2,000.0 


FIG. 18 


PTO Management Company Invoice 

Invoice Date: July 22, 1997 


Item: 

Check Number: 1511 
From Account: 

58-67-9785 - PTFM Checks for U.S. PTO 
Request by: 

Brian Lorson on: 07/22/1997 12:53:16 
Client Number 00997 Matter Number xxxx 
Note: This requires special attention. 




Check Amount: 
Fee: 


' $ 2.000.0 
$ 118.75 


Total Oue By 09/20/1997: 


X 2.118.75 


Discounted Total Oue If Paid By 08/11/1997: 
Discounted Total Due If Paid By 08/11/1997: 


\ 2.029.69 
t 2.059.38 


FIG. 19 



Deposit Account Authorization 


PTFM EPO Deposit Account 


Account Number XYZ234784 


Authorization Number: SLWK00021023 




Date Fee Code 


Check Amount 


July 22, 1997 sdhfsfd 


$ 500.0 


Payee: European Patent Office 




Requested by: Brian Larson 


on: 07/22/1997 t2:44:18 


Cfient Number 00999 




Matter Number sfgs 


Fee Assessed: | $ 6.75 | 



FIG. 20 



PTO Management Company Invoice 

Invoice Dote: July 22, 1997 


Item: 






Authorization Number: SLWK00021023 




From Account: 






XYZ234784 - PTFM EPO Dep 


Dsit Account 




Request by: 






Brian Larson 


on: 07/22/1997 12:53:16 




Client Number 00999 


Matter Number, xxxx 






Authorization Amount: 


$ 300.0 




Fee: 


$ 6.75 




Total Oue By 08/21/1997: 


$ 306.75 


FIG. 21 
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Database: PTFM 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page : 



C : \PMCSOURCE\ACCOUNT . DBF 



07/15/1997 
1252 



Field 


Field Name 






Width 


Dec 


1 


AC_C0DE 






8 




2 


AC NAME 






30 




3 


AC_CLIENTNUM. . 






10 




4 


AC CLIENTNAM. . 






50 




5 


AC ACCOUNTNU . . 






20 




6 


AC ACCOUNTTY . . 






18 




7 


AC BALANCE 






12 


2 


8 


AC NEXTCHECK 






10 




** Total ** 






159 




Structure 


for table: 




Number of 


data records: 




Date of last update: 




Memo file 


block size: 




Code Page: 




Field 


Field Name 






Width 


Dec 


1 


AT TYPE 






18 




2 


AT KEEPBALAN. . 






1 




3 


AT TRANSTYPE . . 






4 




4 


AT PAYEES 






4 




5 


AT CANEXCEED 






1 




6 


AT CHARGE FEE 






1 





Type 




Index Collate 


Nulls 


Character 




Asc Machine 


NO 


Character 




Asc Machine 


No 


Character 






NO 


Character 






No 


Character 






NO 


Character 






NO 


Numeric 






No 


Numeric 






No 



C : \PMCSOURCE\ACCTTYPE . DBF 



06/10/1997 
64 

1252 

Type 
Index Collate 
Character 

Logical 

Memo 

Memo 

Logical 

Logical 



Nulls 
No 
No 
No 
No 
No 
No 



FIG. 24A 
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7 


AT CHECKONLY 
1 


Logical 


No 


8 


AT AUTHORIZA . . 
1 


Logical 


No 


9 


AT USPTOCODE 
1 


Logical 


No 


10 


AT EPOCODE 
1 


Logical 


No 


11 


AT EXPORTTOP. . 
1 


Logical 


No 



** Total ** 



35 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 

Field Field Name 
Width 

1 CL_CLIENTNUM . 

10 

2 CL_NAME 

50 

3 CL_PLAN 

20 



C : \PMCSOURCE\CLIENT . DBF 



** Total ** 



81 



Structure for table: 
Number of data records : 
Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 
Width 

1 DE_CODE 

8 

2 DE_CL I ENTNUM . 

20 

3 DE_MATTERNUM. 

20 

4 DE_DATET I ME 

8 

5 DE_TRANSACT I . 

3 



06/20/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 



Nulls 
No 
No 
NO 



C : \PMCSOURCE\DETAIL . DBF 

69 

07/15/1997 
64 

1252 

Type 

Dec Index Collate 

Character 



Character 
Character 
DateTime 
Character 



Nulls 
No 
No 
No 
No 
No 



FIG. 24B 



D 






Character 






cn 






No 


7 






Character 






7 R 
/ D 






No 


Q 

o 






Numeric 






J. u 


£. 




No 


9 


FIR PT.TIQMTNT71Q 




Numeric 






2 






No 








Character 












No 


1 1 
J. J. 


L>E« i_(Ul_AIlUJN 




Character 






10 






No 


1Z 






Numeric 






1U 






No 








Memo 






4 






No 


Ifl 


T"\C PPfl 
UtL_t Cttil 




Numeric 






8 


2 




No 


J. D 


np naTcnTTPi 

U£i U/\ 1 IltJJ U Ej J. 




Date 






8 






No 


16 






Numeric 






8 


2 




No 


17 


IJfc.__UA I hDUb z 




Date 






8 






No 


18 


DE FEE3 




Numeric 






8 


2 




No 


19 


DE DATEDUE3 




Date 






8 






No 


o n 
z u 


T\rp CT&T1TC 




Character 






17 






No 


21 


DE SELECTED 




Logical 






1 






No 


22 


DE PRINTDATE. . 




DateTime 






8 






No 


23 


DE EXPORTDAT. . 




DateTime 






8 






No 


** Total 


** 










328 








Structure 


for table: 




C : \PMCSOURCE\PTOCODE . DBF 


Number of 


data records: 


149 







Date of last update: 
Code Page: 

Field Field Name 
Width 



Dec 



05/16/1997 
1252 

Type 
Index Collate 



Nulls 



FIG. 24C 



1 

2 

** Total ** 



PT_CODE 
75 

PTJJSPTOCODE 
1 

77 



Structure for table : . 
Number of data records: 
Date of last update: 
Code Page: 



Character 
Logical 



C : \PMCSOURCE\RATE . DBF 

48 

06/27/1997 
1252 



NO 
No 



Id 


Field Name 




Type 






Width 


Dec 


Index Collate 


Nulls 


1 


RA PLAN 
20 




Character 


No 


2 


RA LOWERLIMI. 




Numeric 






8 


2 




No 


3 


RA UPPERLIMI. 




Numeric 






8 


2 




No 


4 


RA DAY S DUE 1 
3 




Numeric 


No 


5 


RA AMOUNT 1 




Numeric 






8 


2 




No 


6 


RA DAYSDUE2 
3 




Numeric 


No 


7 


RA AMOUNT 2 




Numeric 






8 


2 




No 


8 


RA DAYS DUE 3 
3 




Numeric 


No 


9 


RA_AM0UNT3 




Numeric 






8 


2 




No 


10 


RA NOTALLOWE. 
1 




Logical 


No 



** Total ** 



71 



Structure for table: 
Number of data records: 
Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 
Width 
1 SU_ITEM 
20 



Dec 



C : \PMCSOURCE\SETUP . DBF 

10 

07/22/1997 
64 

1252 

Type 

Index Collate Nulls 
Character 

No 



PIG- 24D 



2 SU_NUMBER 

10 

3 SU_DATA 

4 

** Total ** 

35 



Numeric 
Memo 



No 
No 



Structure for table: 
Number of data records : 
Date of last update: 
Code Page: 



C : \PMCSOURCE\TRANTYPE . DBF 



06/10/1997 
1252 



Field 


Field Name 


Type 






Width Dec 


Index Collate 


Nulls 


1 


TR TRANSACT I . . 
3 


Character 


No 


2 


TR DESCRIPTI. . 
20 


Character 


No 


3 


TR PLUSMINUS 
2 


Numeric 


No 


4 


TR CHKACCTVA. . 
1 


Logical 


No 


5 


TR AUTACCTVA. . 
1 


Logical 


No 


6 


TR CHKLIMITE . . 
1 


Logical 


No 


7 


TR AUTLIMITE . . 
1 


Logical 


No 


8 


TR CHARGEFEE 
1 


Logical 


NO 


Total 


** 

31 







Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 

Field Field Name 
Width 

1 US_ID 

20 

2 US_LAST 

15 

3 US_FIRST 

15 

4 US_PASSWORD 

15 



C : \PMCSOURCE\USER . DBF 



05/02/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 

Character 



Nulls 
No 
No 
No 
No 



FIG. 24E 
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5 


US_CHECKBALA . . 
1 


Logical 


No 


6 


US VIEWREQUE . . 
1 


Logical 


NO 


7 


US CREATEREQ. . 
1 


Logical 


NO 


8 


US CANCELREQ. . 
1 


Logical 


No 


9 


US MODIFYACC. . 
1 


Logical 


No 


10 


US PRINTREPO. . 
1 


Logical 


No 


11 


US EXTRACTDA . . 
1 


Logical 


No 



** Total ** 



Program File: MAIN.PRG 

^SCREEN. Width =633 
_SCREEN. Height =418 
_SCREEN. Icon = "opening . ico" 

SET CENTURY ON 

SET BELL OFF 

SET CONFIRM ON 

SET DELETED ON 

SET MULTILOCKS ON 

SET PROCEDURE TO MAIN.PRG 

OPEN DATABASE PTFM 

PUBLIC frmMenu, gcLoginID, gcFullName, gcLocation, gcProgName 

USE Setup 

SET ORDER TO- Item 

IF SEEK ( n PROGNAME " ) 

gcProgName » TRIM (Setup. SU_Dat a) 

_SCREEN. Caption = gcProgName 

ELSE 

gcProgName = "Patent & Trademark Fee Management" 

END IF 

IF SEEK { " LOGINID " ) 

gcLoginID = TRIM (Setup . SU_Dat a) 

ELSE 

gcLoginID = "Unknown" 
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END IF 



IF SEEK ( " FULLNAME " ) 

gcFullName = TRIM (Setup. SU__Data) 

ELSE 

gcFullName = "Unknown" 

ENDIF 

IF SEEK ("LOCATION") 

gcLocation = TRIM (Setup. SU_Data) 

ELSE 

gcLocation = "Unknown" 

ENDIF 

CLOSE TABLES ALL 

DO FORM Menu NAME frmMenu 

READ EVENTS 

************************************* 

FUNCTION GetDueDate 

* Finds the Monday which is the specified number of weeks after 

* the date the request was made. If the request was made on a 

* Monday, do not count that Monday. 
LPARAMETERS ldDate, InNumMondays 

Local InMondayCnt 

InMondayCnt = 0 

DO WHILE InMondayCnt < InNumMondays 
ldDate = ldDate +1 
IF DOW (ldDate, 2) = 1 

InMondayCnt = InMondayCnt + 1 

ENDIF 

ENDDO 

RETURN ldDate 

************************************* 

FUNCTION TextDollar 

PARAMETERS nNumber 

LOCAL InDollars, InCents 

InDollars = INT (nNumber) 

InCents = (nNumber - InDollars) * 100 
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RETURN TextNumeric (lnDollars)+ n AND "+STR (InCents, 2) +"/100 
DOLLARS" 

************************************* 
FUNCTION TextNumeric 

PARAMETERS nNumber 

LOCAL lcString, InWorkNumber 

InWorkNumber = nNumber 
lcString m »» 

IF InWorkNumber >= 1000000 

lcString = TextNumeric (InWorkNumber/ 10 00 000) + "Million " 

InWorkNumber = InWorkNumber - 
<INT(lnWorkNumber/1000000) *1000000) 
END IF 

IF InWorkNumber >= 1000 

lcString * lcString + TextNumeric (InWorkNumber/ 1000) + 
"Thousand " 

InWorkNumber = InWorkNumber - (INT (InWorkNumber/ 10 00) *1000) 

ENDIF 
DO CASE 

CASE InWorkNumber >= 900 

lcString =* lcString + "Nine Hundred " 

InWorkNumber = InWorkNumber - 900 
CASE InWorkNumber >= 800 

lcString = lcString + "Eight Hundred " 

InWorkNumber = InWorkNumber - 800 
CASE InWorkNumber >= 700 

lcString = lcString + "Seven Hundred " 

InWorkNumber = InWorkNumber - 700 
CASE InWorkNumber >= 600 

lcString » lcString + "Six Hundred " 

InWorkNumber = InWorkNumber - 600 
CASE InWorkNumber >= 500 

lcString = lcString + "Five Hundred " 

InWorkNumber = InWorkNumber - 500 
CASE InWorkNumber >= 400 

lcString = lcString + "Four Hundred " 

InWorkNumber = InWorkNumber - 400 
CASE InWorkNumber >= 300 

lcString = lcString + "Three Hundred " 

InWorkNumber = InWorkNumber - 300 
CASE InWorkNumber >= 200 



FIG. 24H 



lcString lcString + "Two Hundred 
InWorkNumber = InWorkNumber - 200 

CASE InWorkNumber >= 100 

lcString = lcString + "One Hundred 
InWorkNumber = InWorkNumber - 100 

ENDCASE 

DO CASE 

CASE InWorkNumber >= 90 

lcString = lcString + "Ninety " 
InWorkNumber = InWorkNumber - 90 

CASE InWorkNumber >= 80 

lcString ■ lcString + "Eighty " 
InWorkNumber = InWorkNumber - 80 

CASE InWorkNumber >= 70 

lcString = lcString + "Seventy " 
InWorkNumber = InWorkNumber - 70 

CASE InWorkNumber >= 60 

lcString = lcString + "Sixty " 
InWorkNumber * InWorkNumber - 60 

CASE InWorkNumber >= 50 

lcString = lcString + "Fifty " 
InWorkNumber = InWorkNumber - 50 

CASE InWorkNumber 40 

lcString = lcString + "Forty " 
InWorkNumber = InWorkNumber - 40 

CASE InWorkNumber >= 30 

lcString = lcString + "Thirty " 
InWorkNumber = InWorkNumber - 30 

CASE InWorkNumber >= 20 

lcString = lcString + "Twenty " 
InWorkNumber = InWorkNumber - 2 0 

CASE InWorkNumber >= 19 

lcString = lcString + "Nineteen " 
InWorkNumber = InWorkNumber - 19 

CASE InWorkNumber 18 

lcString = lcString + "Eighteen " 
InWorkNumber - InWorkNumber - 18 

CASE InWorkNumber >= 17 

lcString « lcString + "Seventeen " 
InWorkNumber = InWorkNumber 17 

CASE InWorkNumber >= 16 

lcString = lcString + "Sixteen " 
InWorkNumber = InWorkNumber - 16 

CASE InWorkNumber >= 15 

lcString = lcString + "Fifteen " 
InWorkNumber = InWorkNumber - 15 
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CASE InWorkNumber >= 14 

lcString = lcString + "Fourteen " 
InWorkNumber - InWorkNumber - 14 

CASE InWorkNumber >= 13 

lcString = lcString + "Thirteen " 
InWorkNumber = InWorkNumber - 13 

CASE InWorkNumber >= 12 

lcString ■ lcString + "Twelve " 
InWorkNumber = InWorkNumber - 12 

CASE InWorkNumber >= 11 

lcString = lcString + "Eleven " 
InWorkNumber = InWorkNumber - 11 

CASE InWorkNumber >= 10 

lcString = lcString + "Ten " 
InWorkNumber = InWorkNumber - 10 

ENDCASE 

DO CASE 

CASE InWorkNumber >= 9 

lcString o lcString + "Nine " 
InWorkNumber = InWorkNumber - 9 

CASE InWorkNumber >= 8 

lcString = lcString + "Eight " 
InWorkNumber = InWorkNumber - 8 

CASE InWorkNumber >= 7 

lcString = lcString + "Seven " 
InWorkNumber = InWorkNumber - 7 

CASE InWorkNumber >= 6 

lcString = lcString + "Six " 
InWorkNumber « InWorkNumber - 6 

CASE InWorkNumber >= 5 

lcString = lcString + "Five " 
InWorkNumber = InWorkNumber - 5 

CASE InWorkNumber >= 4 

lcString = lcString + "Four " 
InWorkNumber = InWorkNumber - 4 

CASE InWorkNumber >= 3 

lcString = lcString + "Three " 
InWorkNumber = InWorkNumber - 3 

CASE InWorkNumber >= 2 

lcString = lcString + "Two " 
InWorkNumber = InWorkNumber - 2 

CASE InWorkNumber >= 1 

lcString = lcString + "One " 
InWorkNumber = InWorkNumber - 1 

ENDCASE 



FIG. 24J 



Page 85 of 85 



IF EMPTY (lcSt ring) 

lcString = "No » 

ENDIF 

RETURN lcString 
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